Skip to content

[ICE0208] WEEK 02 solutions#2680

Open
ICE0208 wants to merge 5 commits into
DaleStudy:mainfrom
ICE0208:week02
Open

[ICE0208] WEEK 02 solutions#2680
ICE0208 wants to merge 5 commits into
DaleStudy:mainfrom
ICE0208:week02

Conversation

@ICE0208

@ICE0208 ICE0208 commented Jun 29, 2026

Copy link
Copy Markdown
Member

답안 제출 문제

작성자 체크 리스트

  • Projects의 오른쪽 버튼(▼)을 눌러 확장한 뒤, Week를 현재 주차로 설정해주세요.
  • 문제를 모두 푸시면 프로젝트에서 StatusIn Review로 설정해주세요.
  • 코드 검토자 1분 이상으로부터 승인을 받으셨다면 PR을 병합해주세요.

검토자 체크 리스트

Important

본인 답안 제출 뿐만 아니라 다른 분 PR 하나 이상을 반드시 검토를 해주셔야 합니다!

  • 바로 이전에 올라온 PR에 본인을 코드 리뷰어로 추가해주세요.
  • 본인이 검토해야하는 PR의 답안 코드에 피드백을 주세요.
  • 토요일 전까지 PR을 병합할 수 있도록 승인해주세요.

@dalestudy

dalestudy Bot commented Jun 29, 2026

Copy link
Copy Markdown
Contributor

📊 ICE0208 님의 학습 현황

이번 주 제출 문제

문제 난이도 유형 분석
3sum Medium ✅ 의도한 유형
climbing-stairs Easy ✅ 의도한 유형
product-of-array-except-self Medium ✅ 의도한 유형
valid-anagram Easy ✅ 의도한 유형
valid-anagram Easy ✅ 의도한 유형
validate-binary-search-tree Medium ✅ 의도한 유형

누적 학습 요약

  • 풀이한 문제: 5 / 75개
  • 이번 주 유형 일치율: 100% (6문제 중 6문제 일치)

문제 풀이 현황

카테고리 진행도 완료
Heap ■■□□□□□ 1 / 3 (Medium 1)
Array ■□□□□□□ 2 / 10 (Easy 2)
Graph ■□□□□□□ 1 / 8 (Medium 1)
Dynamic Programming ■□□□□□□ 1 / 11 (Medium 1)
Binary □□□□□□□ 0 / 5 ← 아직 시작 안 함
Interval □□□□□□□ 0 / 5 ← 아직 시작 안 함
Linked List □□□□□□□ 0 / 6 ← 아직 시작 안 함
Matrix □□□□□□□ 0 / 4 ← 아직 시작 안 함
String □□□□□□□ 0 / 10 ← 아직 시작 안 함
Tree □□□□□□□ 0 / 14 ← 아직 시작 안 함

🤖 이 댓글은 GitHub App을 통해 자동으로 작성되었습니다.

🔢 API 사용량 (gpt-5-nano)
요청 입력 토큰 출력 토큰 합계 비용
1 811 89 900 $0.000076
2 1,345 151 1,496 $0.000128
3 1,895 188 2,083 $0.000170
4 2,477 239 2,716 $0.000219
5 3,034 250 3,284 $0.000252
합계 9,562 917 10,479 $0.000845

@essaysir essaysir self-requested a review June 30, 2026 09:12
Comment thread 3sum/ICE0208.java

Copy link
Copy Markdown
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

🏷️ 알고리즘 패턴 분석

  • 패턴: Two Pointers, Hash Map / Hash Set, Dynamic Programming
  • 설명: 정렬 후 i를 고정하고 나머지에서 Two Sum을 해법으로 사용하며, j를 증가시키며 방문 값들을 Hash Set으로 관리한다. 부분적으로 중복 제거를 위한 조건도 포함되어 있어, 두 포인터 대신 해시셋 기반의 탐색으로 구현되는 패턴이 보인다.

📊 시간/공간 복잡도 분석

복잡도
Time O(n^2)
Space O(n)

피드백: 정렬 후 두 중첩 루프와 해시 집합으로 중복을 제거하는 방식이다. 최악의 경우 모든 쌍을 확인하므로 시간복잡도는 O(n^2)이고 추가 공간은 해시집합으로 O(n)이다.

개선 제안: 고려해볼 만한 대안: 기준값 고정 시 투포인터를 사용하면 해시세트 없이도 O(n^2) 시간과 O(1) 추가 공간으로 구현 가능하다.

💡 풀이에 시간/공간 복잡도를 주석으로 남겨보세요!

Copy link
Copy Markdown
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

🏷️ 알고리즘 패턴 분석

  • 패턴: Dynamic Programming, Greedy
  • 설명: 피보나치 유사식 dp[i] = dp[i-1] + dp[i-2]로 계단 수를 구하는 대표적인 DP 문제이며, 공간을 1차원 배열 없이 두 변수로 최적화하는 기법은 DP 패턴에 해당합니다. 그 외 특정 탐색이나 정렬 요소는 사용되지 않습니다.

📊 시간/공간 복잡도 분석

복잡도
Time O(n)
Space O(1)

피드백: 두 변수만으로 이차식 점화식을 순회하며 필요한 값을 얻는다. 배열 전체를 사용하지 않아 공간을 절약한다.

개선 제안: 현재 구현이 적절해 보입니다.

💡 풀이에 시간/공간 복잡도를 주석으로 남겨보세요!

Copy link
Copy Markdown
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

🏷️ 알고리즘 패턴 분석

  • 패턴: Two Pointers, Sliding Window, Hash Map / Hash Set, Dynamic Programming, Greedy, Divide and Conquer, Bit Manipulation, Trie, Union Find, Heap / Priority Queue, BFS, DFS, Backtracking, Monotonic Stack, Binary Search
  • 설명: 주요 아이디어는 왼쪽 곱과 오른쪽 곱을 누적해 결과를 구하는 방식으로, 추가 저장공간 없이 부분구간 누적 곱을 이용하는 기법이다. 두 번의 순회를 통해 각 위치의 좌우 누적 곱을 합성해 최종 결과를 얻는다.

📊 시간/공간 복잡도 분석

복잡도
Time O(n)
Space O(1)

피드백: 좌우 누적곱을 한 번의 순회로 계산해 각 원소에 대해 자신을 제외한 곱을 얻는다. 추가 배열 없이 결과를 구성한다.

개선 제안: 현재 구현이 적절해 보입니다.

💡 풀이에 시간/공간 복잡도를 주석으로 남겨보세요!

Copy link
Copy Markdown
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

🏷️ 알고리즘 패턴 분석

  • 패턴: Hash Map / Hash Set, Bit Manipulation, Dynamic Programming, Two Pointers, Sliding Window, Fast & Slow Pointers, BFS, DFS, Backtracking, Divide and Conquer, Union Find, Trie, Monotonic Stack, Heap / Priority Queue, Greedy, Binary Search, Dynamic Programming, Bit Manipulation
  • 설명: 주어진 코드는 각 문자열의 알파벳 등장 횟수를 비교하기 위해 고정 배열로 카운트를 세고, 최종적으로 배열 비교로 동일성을 판단한다. 이는 해시 맵 없이도 빈도 수를 비교하는 전형적 패턴으로, 문자 빈도 기반 비교에 해당한다.

📊 시간/공간 복잡도 분석

복잡도
Time O(n + m)
Space O(1)

피드백: 두 문자열의 문자 빈도를 비교하는 전형적인 해시 기반 방법이다.

개선 제안: 현재 구현이 적절해 보입니다.

💡 풀이에 시간/공간 복잡도를 주석으로 남겨보세요!

Comment thread valid-anagram/ICE0208.py

Copy link
Copy Markdown
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

🏷️ 알고리즘 패턴 분석

  • 패턴: Hash Map / Hash Set, Sorting
  • 설명: 두 문자열의 문자 빈도 비교로 동형 여부를 판단하는 방식은 해시 맵(또는 Counter)을 사용한 패턴에 해당한다. 또한 정렬 비교 방식은 기본적으로 정렬 알고리즘을 활용하는 일반적인 패턴으로 볼 수 있다.

📊 시간/공간 복잡도 분석

복잡도
Time O(n + m)
Space O(1)

피드백: 두 문자열의 문자 빈도를 비교하는 전형적인 해시 기반 방법이다.

개선 제안: 현재 구현이 적절해 보입니다.

💡 풀이에 시간/공간 복잡도를 주석으로 남겨보세요!

Copy link
Copy Markdown
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

🏷️ 알고리즘 패턴 분석

  • 패턴: Binary Search, Depth-First Search, Divide and Conquer, Hash Map / Hash Set
  • 설명: 트리를 중위 순회 비슷한 방식으로 각 노드의 허용 범위를 재귀적으로 확인하고, 분할된 하위 트리에서 독립적으로 조건을 검사한다. 재귀를 통해 좌우 자식을 각각 다룬다는 점에서 DFS 및 분할된 문제 해결 패턴이 함께 작용한다.

📊 시간/공간 복잡도 분석

복잡도
Time O(n)
Space O(h)

피드백: 각 노드를 한 번씩 방문하고 경계값을 업데이트한다.

개선 제안: 현재 구현이 적절해 보입니다.

💡 풀이에 시간/공간 복잡도를 주석으로 남겨보세요!

@ICE0208 ICE0208 moved this from Solving to In Review in 리트코드 스터디 8기 Jul 1, 2026
Comment on lines +27 to +33
for (int i = 3; i <= n; i++) {
int curr = prev1 + prev2; // dp[i]
prev2 = prev1;
prev1 = curr;
}

return prev1;

Copy link
Copy Markdown
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

안녕하세요. 이번 주 리뷰를 맡게된 손주선이라고 합니다.
저는 memoization 방식으로 해결했는데,
이렇게 푸는 방식이 있었네요. 이러한 생각을 어떠한 흐름으로 가지게 되셨던 것이지 궁금합니다.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Projects

Status: In Review

Development

Successfully merging this pull request may close these issues.

2 participants